#### 15.0 INSTRUCTION SET SUMMARY

The PIC16F882/883/884/886/887 instruction set is highly orthogonal and is comprised of three basic categories:

- Byte-oriented operations
- · Bit-oriented operations
- · Literal and control operations

Each PIC16 instruction is a 14-bit word divided into an **opcode**, which specifies the instruction type and one or more **operands**, which further specify the operation of the instruction. The formats for each of the categories is presented in Figure 15-1, while the various opcode fields are summarized in Table 15-1.

Table 15-2 lists the instructions recognized by the MPASM $^{TM}$  assembler.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is zero, the result is placed in the W register. If 'd' is one, the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator, which selects the bit affected by the operation, while 'f' represents the address of the file in which the bit is located.

For **literal and control** operations, 'k' represents an 8-bit or 11-bit constant, or literal value.

One instruction cycle consists of four oscillator periods; for an oscillator frequency of 4 MHz, this gives a normal instruction execution time of 1  $\mu s$ . All instructions are executed within a single instruction cycle, unless a conditional test is true, or the program counter is changed as a result of an instruction. When this occurs, the execution takes two instruction cycles, with the second cycle executed as a NOP.

All instruction examples use the format '0xhh' to represent a hexadecimal number, where 'h' signifies a hexadecimal digit.

#### 15.1 Read-Modify-Write Operations

Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (RMW) operation. The register is read, the data is modified, and the result is stored according to either the instruction, or the destination designator 'd'. A read operation is performed on a register even if the instruction writes to that register.

For example, a CLRF PORTA instruction will read PORTA, clear all the data bits, then write the result back to PORTA. This example would have the unintended consequence of clearing the condition that set the RAIF flag.

TABLE 15-1: OPCODE FIELD DESCRIPTIONS

| Field | Description                                                                                                                                                         |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f     | Register file address (0x00 to 0x7F)                                                                                                                                |
| W     | Working register (accumulator)                                                                                                                                      |
| b     | Bit address within an 8-bit file register                                                                                                                           |
| k     | Literal field, constant data or label                                                                                                                               |
| х     | Don't care location (= 0 or 1). The assembler will generate code with x = 0. It is the recommended form of use for compatibility with all Microchip software tools. |
| d     | Destination select; $d = 0$ : store result in W, $d = 1$ : store result in file register f. Default is $d = 1$ .                                                    |
| PC    | Program Counter                                                                                                                                                     |
| TO    | Time-out bit                                                                                                                                                        |
| С     | Carry bit                                                                                                                                                           |
| DC    | Digit carry bit                                                                                                                                                     |
| Z     | Zero bit                                                                                                                                                            |
| PD    | Power-down bit                                                                                                                                                      |

FIGURE 15-1: GENERAL FORMAT FOR INSTRUCTIONS



TABLE 15-2: PIC16F882/883/884/886/887 INSTRUCTION SET

| Mnemonic,<br>Operands |                                        | Description                  | Cycles 14-Bit |        | Opcode |      | Status | Notes    |         |
|-----------------------|----------------------------------------|------------------------------|---------------|--------|--------|------|--------|----------|---------|
|                       |                                        | Description                  |               | MSb    |        |      | LSb    | Affected | Notes   |
|                       | BYTE-ORIENTED FILE REGISTER OPERATIONS |                              |               |        |        |      |        |          |         |
| ADDWF                 | f, d                                   | Add W and f                  | 1             | 0.0    | 0111   | dfff | ffff   | C, DC, Z | 1, 2    |
| ANDWF                 | f, d                                   | AND W with f                 | 1             | 00     | 0101   | dfff | ffff   | Z        | 1, 2    |
| CLRF                  | f                                      | Clear f                      | 1             | 00     | 0001   | lfff | ffff   | Z        | 2       |
| CLRW                  | _                                      | Clear W                      | 1             | 00     | 0001   | 0xxx | xxxx   | Z        |         |
| COMF                  | f, d                                   | Complement f                 | 1             | 00     | 1001   | dfff | ffff   | Z        | 1, 2    |
| DECF                  | f, d                                   | Decrement f                  | 1             | 00     | 0011   | dfff | ffff   | Z        | 1, 2    |
| DECFSZ                | f, d                                   | Decrement f, Skip if 0       | 1(2)          | 00     | 1011   | dfff | ffff   |          | 1, 2, 3 |
| INCF                  | f, d                                   | Increment f                  | 1             | 00     | 1010   | dfff | ffff   | Z        | 1, 2    |
| INCFSZ                | f, d                                   | Increment f, Skip if 0       | 1(2)          | 00     | 1111   | dfff | ffff   |          | 1, 2, 3 |
| IORWF                 | f, d                                   | Inclusive OR W with f        | ì             | 00     | 0100   | dfff | ffff   | Z        | 1, 2    |
| MOVF                  | f, d                                   | Move f                       | 1             | 00     | 1000   | dfff | ffff   | Z        | 1, 2    |
| MOVWF                 | f                                      | Move W to f                  | 1             | 00     | 0000   | lfff | ffff   |          |         |
| NOP                   | _                                      | No Operation                 | 1             | 00     | 0000   | 0xx0 | 0000   |          |         |
| RLF                   | f, d                                   | Rotate Left f through Carry  | 1             | 00     | 1101   | dfff | ffff   | С        | 1, 2    |
| RRF                   | f, d                                   | Rotate Right f through Carry | 1             | 00     | 1100   | dfff | ffff   | С        | 1, 2    |
| SUBWF                 | f, d                                   | Subtract W from f            | 1             | 00     | 0010   | dfff | ffff   | C, DC, Z | 1, 2    |
| SWAPF                 | f, d                                   | Swap nibbles in f            | 1             | 00     | 1110   | dfff | ffff   |          | 1, 2    |
| XORWF                 | f, d                                   | Exclusive OR W with f        | 1             | 00     | 0110   | dfff | ffff   | Z        | 1, 2    |
|                       |                                        | BIT-ORIENTED FILE REGIST     | ER OPER       | RATION | ıs     |      |        |          |         |
| BCF                   | f, b                                   | Bit Clear f                  | 1             | 01     | 00bb   | bfff | ffff   |          | 1, 2    |
| BSF                   | f, b                                   | Bit Set f                    | 1             | 01     | 01bb   | bfff | ffff   |          | 1, 2    |
| BTFSC                 | f, b                                   | Bit Test f, Skip if Clear    | 1 (2)         | 01     | 10bb   | bfff | ffff   |          | 3       |
| BTFSS                 | f, b                                   | Bit Test f, Skip if Set      | 1 (2)         | 01     | 11bb   | bfff | ffff   |          | 3       |
|                       |                                        | LITERAL AND CONTROL          | OPERAT        | IONS   |        |      |        |          |         |
| ADDLW                 | k                                      | Add literal and W            | 1             | 11     | 111x   | kkkk |        | C, DC, Z |         |
| ANDLW                 | k                                      | AND literal with W           | 1             | 11     | 1001   | kkkk | kkkk   | Z        |         |
| CALL                  | k                                      | Call Subroutine              | 2             | 10     | 0kkk   | kkkk | kkkk   |          |         |
| CLRWDT                | _                                      | Clear Watchdog Timer         | 1             | 00     | 0000   | 0110 | 0100   | TO, PD   |         |
| GOTO                  | k                                      | Go to address                | 2             | 10     | 1kkk   | kkkk | kkkk   |          |         |
| IORLW                 | k                                      | Inclusive OR literal with W  | 1             | 11     | 1000   | kkkk | kkkk   | Z        |         |
| MOVLW                 | k                                      | Move literal to W            | 1             | 11     | 00xx   | kkkk | kkkk   |          |         |
| RETFIE                | _                                      | Return from interrupt        | 2             | 0.0    | 0000   | 0000 | 1001   |          |         |
| RETLW                 | k                                      | Return with literal in W     | 2             | 11     | 01xx   | kkkk | kkkk   |          |         |
| RETURN                | -                                      | Return from Subroutine       | 2             | 00     | 0000   | 0000 | 1000   |          |         |
| SLEEP                 | -                                      | Go into Standby mode         | 1             | 00     | 0000   | 0110 | 0011   | TO, PD   |         |
| SUBLW                 | k                                      | Subtract w from literal      | 1             | 11     | 110x   | kkkk | kkkk   | C, DC, Z |         |
| XORLW                 | k                                      | Exclusive OR literal with W  | 1             | 11     | 1010   | kkkk | kkkk   | Z        |         |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF GPIO, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

<sup>2:</sup> If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module.

<sup>3:</sup> If the Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

#### 15.2 Instruction Descriptions

| ADDLW            | Add literal and W                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] ADDLW k                                                                                               |
| Operands:        | $0 \leq k \leq 255$                                                                                           |
| Operation:       | $(W) + k \rightarrow (W)$                                                                                     |
| Status Affected: | C, DC, Z                                                                                                      |
| Description:     | The contents of the W register are added to the 8-bit literal 'k' and the result is placed in the W register. |

| BCF              | Bit Clear f                          |
|------------------|--------------------------------------|
| Syntax:          | [ label] BCF f,b                     |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$ |
| Operation:       | $0 \rightarrow (f < b >)$            |
| Status Affected: | None                                 |
| Description:     | Bit 'b' in register 'f' is cleared.  |

| ADDWF            | Add W and f                                                                                                                                                            |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] ADDWF f,d                                                                                                                                                    |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                     |
| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                                  |
| Status Affected: | C, DC, Z                                                                                                                                                               |
| Description:     | Add the contents of the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. |

| BSF              | Bit Set f                            |
|------------------|--------------------------------------|
| Syntax:          | [ label ] BSF f,b                    |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$ |
| Operation:       | $1 \rightarrow (f < b >)$            |
| Status Affected: | None                                 |
| Description:     | Bit 'b' in register 'f' is set.      |
|                  |                                      |

| ANDLW            | AND literal with W                                                                                        |
|------------------|-----------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] ANDLW k                                                                                           |
| Operands:        | $0 \leq k \leq 255$                                                                                       |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                           |
| Status Affected: | Z                                                                                                         |
| Description:     | The contents of W register are AND'ed with the 8-bit literal 'k'. The result is placed in the W register. |

| BTFSC            | Bit Test f, Skip if Clear                                                                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSC f,b                                                                                                                                                                                           |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$                                                                                                                                                                          |
| Operation:       | skip if (f < b >) = 0                                                                                                                                                                                         |
| Status Affected: | None                                                                                                                                                                                                          |
| Description:     | If bit 'b' in register 'f' is '1', the next instruction is executed.  If bit 'b' in register 'f' is '0', the next instruction is discarded, and a NOP is executed instead, making this a 2-cycle instruction. |

| ANDWF            | AND W with f                                                                                                                                           |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] ANDWF f,d                                                                                                                                    |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                     |
| Operation:       | (W) .AND. (f) $\rightarrow$ (destination)                                                                                                              |
| Status Affected: | Z                                                                                                                                                      |
| Description:     | AND the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. |

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                                               |
| Operands:        | $0 \le f \le 127$<br>$0 \le b < 7$                                                                                                                                                                |
| Operation:       | skip if $(f < b >) = 1$                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                              |
| Description:     | If bit 'b' in register 'f' is '0', the next instruction is executed.  If bit 'b' is '1', then the next instruction is discarded and a NOP is executed instead, making this a 2-cycle instruction. |

| CLRWDT           | Clear Watchdog Timer                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] CLRWDT                                                                                                         |
| Operands:        | None                                                                                                                     |
| Operation:       | $00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{TO}$ $1 \rightarrow \overline{PD}$ |
| Status Affected: | TO, PD                                                                                                                   |
| Description:     | CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits TO and PD are set.    |

| CALL             | Call Subroutine                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CALL k                                                                                                                                                                                                        |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                  |
| Operation:       | (PC)+ 1 $\rightarrow$ TOS,<br>k $\rightarrow$ PC<10:0>,<br>(PCLATH<4:3>) $\rightarrow$ PC<12:11>                                                                                                                      |
| Status Affected: | None                                                                                                                                                                                                                  |
| Description:     | Call Subroutine. First, return address (PC + 1) is pushed onto the stack. The 11-bit immediate address is loaded into PC bits <10:0>. The upper bits of the PC are loaded from PCLATH. CALL is a 2-cycle instruction. |

| COMF             | Complement f                                                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] COMF f,d                                                                                                                                 |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                 |
| Operation:       | $(\bar{f}) \rightarrow (destination)$                                                                                                              |
| Status Affected: | Z                                                                                                                                                  |
| Description:     | The contents of register 'f' are complemented. If 'd' is '0', the result is stored in W. If 'd' is '1', the result is stored back in register 'f'. |

| CLRF             | Clear f                                                        |
|------------------|----------------------------------------------------------------|
| Syntax:          | [label] CLRF f                                                 |
| Operands:        | $0 \leq f \leq 127$                                            |
| Operation:       | $00h \to (f)$ $1 \to Z$                                        |
| Status Affected: | Z                                                              |
| Description:     | The contents of register 'f' are cleared and the Z bit is set. |

| DECF             | Decrement f                                                                                                                              |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] DECF f,d                                                                                                                       |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                       |
| Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                      |
| Status Affected: | Z                                                                                                                                        |
| Description:     | Decrement register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. |

| CLRW             | Clear W                                     |
|------------------|---------------------------------------------|
| Syntax:          | [label] CLRW                                |
| Operands:        | None                                        |
| Operation:       | $00h \to (W)$ $1 \to Z$                     |
| Status Affected: | Z                                           |
| Description:     | W register is cleared. Zero bit (Z) is set. |

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] DECFSZ f,d                                                                                                                                                                                                                                                                                           |
| Operands:        | $0 \le f \le 127$<br>d $\in [0,1]$                                                                                                                                                                                                                                                                             |
| Operation:       | (f) - 1 $\rightarrow$ (destination);<br>skip if result = 0                                                                                                                                                                                                                                                     |
| Status Affected: | None                                                                                                                                                                                                                                                                                                           |
| Description:     | The contents of register 'f' are decremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'.  If the result is '1', the next instruction is executed. If the result is '0', then a NOP is executed instead, making it a 2-cycle instruction. |

| INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] INCFSZ f,d                                                                                                                                                                                                                                                                                      |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                        |
| Operation:       | (f) + 1 $\rightarrow$ (destination),<br>skip if result = 0                                                                                                                                                                                                                                                |
| Status Affected: | None                                                                                                                                                                                                                                                                                                      |
| Description:     | The contents of register 'f' are incremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'.  If the result is '1', the next instruction is executed. If the result is '0', a NOP is executed instead, making it a 2-cycle instruction. |

| GOTO             | Unconditional Branch                                                                                                                                                        |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] GOTO k                                                                                                                                                            |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                        |
| Operation:       | $k \rightarrow PC<10:0>$<br>PCLATH<4:3> $\rightarrow$ PC<12:11>                                                                                                             |
| Status Affected: | None                                                                                                                                                                        |
| Description:     | GOTO is an unconditional branch. The 11-bit immediate value is loaded into PC bits <10:0>. The upper bits of PC are loaded from PCLATH<4:3>. GOTO is a 2-cycle instruction. |

| IORLW            | Inclusive OR literal with W                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] IORLW k                                                                                            |
| Operands:        | $0 \leq k \leq 255$                                                                                          |
| Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                 |
| Status Affected: | Z                                                                                                            |
| Description:     | The contents of the W register are OR'ed with the 8-bit literal 'k'. The result is placed in the W register. |

| INCF             | Increment t                                                                                                                                                    |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] INCF f,d                                                                                                                                             |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                             |
| Operation:       | (f) + 1 $\rightarrow$ (destination)                                                                                                                            |
| Status Affected: | Z                                                                                                                                                              |
| Description:     | The contents of register 'f' are incremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. |

| IORWF            | Inclusive OR W with f                                                                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] IORWF f,d                                                                                                                                             |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                              |
| Operation:       | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                        |
| Status Affected: | Z                                                                                                                                                               |
| Description:     | Inclusive OR the W register with register 'f'. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. |

| MOVF             | Move f                                                                                                                                                                                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] MOVF f,d                                                                                                                                                                                                                                              |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                              |
| Operation:       | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                        |
| Status Affected: | Z                                                                                                                                                                                                                                                               |
| Description:     | The contents of register 'f' is moved to a destination dependent upon the status of 'd'. If $d=0$ , destination is W register. If $d=1$ , the destination is file register 'f' itself. $d=1$ is useful to test a file register since status flag Z is affected. |
| Words:           | 1                                                                                                                                                                                                                                                               |
| Cycles:          | 1                                                                                                                                                                                                                                                               |
| Example:         | MOVF FSR, 0                                                                                                                                                                                                                                                     |
|                  | After Instruction  W = value in FSR  register  Z = 1                                                                                                                                                                                                            |

| MOVWF            | Move W to f                                |
|------------------|--------------------------------------------|
| Syntax:          | [label] MOVWF f                            |
| Operands:        | $0 \leq f \leq 127$                        |
| Operation:       | $(W) \rightarrow (f)$                      |
| Status Affected: | None                                       |
| Description:     | Move data from W register to register 'f'. |
| Words:           | 1                                          |
| Cycles:          | 1                                          |
| Example:         | MOVW OPTION<br>F                           |
|                  | Before Instruction                         |
|                  | OPTION = 0xFF                              |
|                  | W = 0x4F                                   |
|                  | After Instruction                          |
|                  | OPTION = 0x4F                              |
|                  | W = 0x4F                                   |
|                  |                                            |
|                  |                                            |
|                  |                                            |

| MOVLW            | Move literal to W                                                                         |
|------------------|-------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] MOVLW k                                                                         |
| Operands:        | $0 \leq k \leq 255$                                                                       |
| Operation:       | $k \rightarrow (W)$                                                                       |
| Status Affected: | None                                                                                      |
| Description:     | The 8-bit literal 'k' is loaded into W register. The "don't cares" will assemble as '0's. |
| Words:           | 1                                                                                         |
| Cycles:          | 1                                                                                         |
| Example:         | MOVLW 0x5A                                                                                |
|                  | After Instruction $W = 0x5A$                                                              |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [ label ] NOP |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |
| Words:           | 1             |
| Cycles:          | 1             |
| Example:         | NOP           |
|                  |               |

| RETFIE           | Return from Interrupt                                                                                                                                                                            |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] RETFIE                                                                                                                                                                                 |
| Operands:        | None                                                                                                                                                                                             |
| Operation:       | $TOS \rightarrow PC$ ,<br>1 $\rightarrow$ GIE                                                                                                                                                    |
| Status Affected: | None                                                                                                                                                                                             |
| Description:     | Return from Interrupt. Stack is POPed and Top-of-Stack (TOS) is loaded in the PC. Interrupts are enabled by setting Global Interrupt Enable bit, GIE (INTCON<7>). This is a 2-cycle instruction. |
| Words:           | 1                                                                                                                                                                                                |
| Cycles:          | 2                                                                                                                                                                                                |
| Example:         | RETFIE                                                                                                                                                                                           |
|                  | After Interrupt PC = TOS GIE = 1                                                                                                                                                                 |

| RETLW            | Return with literal in W                                                                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETLW k                                                                                                                                                                                            |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                                          |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                                                               |
| Status Affected: | None                                                                                                                                                                                                       |
| Description:     | The W register is loaded with the 8-bit literal 'k'. The program counter is loaded from the top of the stack (the return address). This is a 2-cycle instruction.                                          |
| Words:           | 1                                                                                                                                                                                                          |
| Cycles:          | 2                                                                                                                                                                                                          |
| Example:         | CALL TABLE;W contains table                                                                                                                                                                                |
| TABLE            | <pre>; offset value . ;W now has . ; table value . ADDWF PC;W = offset RETLW k1; Begin table RETLW k2; RETLW kn; End of table  Before Instruction     W = 0x07 After Instruction     W = value of k8</pre> |
|                  |                                                                                                                                                                                                            |

| RETURN           | Return from Subroutine                                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] RETURN                                                                                                                             |
| Operands:        | None                                                                                                                                         |
| Operation:       | $TOS \rightarrow PC$                                                                                                                         |
| Status Affected: | None                                                                                                                                         |
| Description:     | Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a 2-cycle instruction. |

| RLF              | Rotate Left f through Carry                                                                                                                                                                           |   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Syntax:          | [ label ] RLF f,d                                                                                                                                                                                     |   |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                    |   |
| Operation:       | See description below                                                                                                                                                                                 |   |
| Status Affected: | С                                                                                                                                                                                                     |   |
| Description:     | The contents of register 'f' are rotated one bit to the left through the Carry flag. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is stored back in register 'f'. |   |
| Words:           | 1                                                                                                                                                                                                     |   |
| Cycles:          | 1                                                                                                                                                                                                     |   |
| Example:         | RLF REG1,0                                                                                                                                                                                            |   |
|                  | Before Instruction                                                                                                                                                                                    |   |
|                  | REG1 = 1110 0110                                                                                                                                                                                      | ) |
|                  | C = 0                                                                                                                                                                                                 |   |
|                  | After Instruction                                                                                                                                                                                     |   |
|                  | After Instruction                                                                                                                                                                                     | ) |
|                  | After Instruction  REG1 = 1110 0110  W = 1100 1100                                                                                                                                                    |   |

| Syntax:          | [label] RRF f,d                                                                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                               |
| Operation:       | See description below                                                                                                                                                            |
| Status Affected: | С                                                                                                                                                                                |
| Description:     | The contents of register 'f' are rotated one bit to the right through the Carry flag. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed |

back in register 'f'.

Register f

**Rotate Right f through Carry** 

RRF

| SLEEP            | Enter Sleep mode                                                                                                                                                                          |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SLEEP                                                                                                                                                                             |
| Operands:        | None                                                                                                                                                                                      |
| Operation:       | 00h → WDT,<br>0 → WDT prescaler,<br>1 → $\overline{TO}$ ,<br>0 → PD                                                                                                                       |
| Status Affected: | TO, PD                                                                                                                                                                                    |
| Description:     | The power-down Status bit, PD is cleared. Time-out Status bit, TO is set. Watchdog Timer and its prescaler are cleared. The processor is put into Sleep mode with the oscillator stopped. |

| SUBLW            | Subtract W from literal                                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SUBLW k                                                                                                          |
| Operands:        | $0 \leq k \leq 255$                                                                                                      |
| Operation:       | $k - (W) \rightarrow (W)$                                                                                                |
| Status Affected: | C, DC, Z                                                                                                                 |
| Description:     | The W register is subtracted (2's complement method) from the 8-bit literal 'k'. The result is placed in the W register. |
|                  | C = 0 $W > k$                                                                                                            |

| <b>C</b> = 0 | W > k                     |
|--------------|---------------------------|
| C = 1        | $W \leq k $               |
| DC = 0       | W<3:0> > k<3:0>           |
| DC = 1       | $W < 3:0 > \le k < 3:0 >$ |

| SUBWF            | Subtract W from f                     |
|------------------|---------------------------------------|
| Syntax:          | [ label ] SUBWF f,d                   |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$    |
| Operation:       | (f) - (W) $\rightarrow$ (destination) |
| Status Affected: | C, DC, Z                              |
| Description:     | Subtract (2's complement method)      |

DC = 0

DC = 1

| Subtract     | Subtract (2's complement method)       |  |  |
|--------------|----------------------------------------|--|--|
| W registe    | er from register 'f'. If 'd' is        |  |  |
| '0', the re  | '0', the result is stored in the W     |  |  |
| register.    | register. If 'd' is '1', the result is |  |  |
| stored ba    | stored back in register 'f'.           |  |  |
|              |                                        |  |  |
| C = 0        | W > f                                  |  |  |
| <b>C</b> = 1 | $W \le f$                              |  |  |

W<3:0> > f<3:0>

 $W < 3:0 > \le f < 3:0 >$ 

| SWAPF            | Swap Nibbles in f                                                                                                                                                      |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SWAPF f,d                                                                                                                                                      |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                     |
| Operation:       | $(f<3:0>) \rightarrow (destination<7:4>),$<br>$(f<7:4>) \rightarrow (destination<3:0>)$                                                                                |
| Status Affected: | None                                                                                                                                                                   |
| Description:     | The upper and lower nibbles of register 'f' are exchanged. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed in register 'f'. |

| XORLW            | Exclusive OR literal with W                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] XORLW k                                                                                               |
| Operands:        | $0 \leq k \leq 255$                                                                                           |
| Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                 |
| Status Affected: | Z                                                                                                             |
| Description:     | The contents of the W register are XOR'ed with the 8-bit literal 'k'. The result is placed in the W register. |

| XORWF            | Exclusive OR W with f                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] XORWF f,d                                                                                                                                                             |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                              |
| Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                       |
| Status Affected: | Z                                                                                                                                                                               |
| Description:     | Exclusive OR the contents of the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. |